package com.gxc.dynamic;

import java.util.Scanner;

/**
 * 有一名科学家想要从一台古董电脑中拷贝文件到自己的电脑中加以研究。
 *
 * 但此电脑除了有一个3.5寸软盘驱动器以外，没有任何手段可以将文件持贝出来，而且只有一张软盘可以使用。
 *
 * 因此这一张软盘是唯一可以用来拷贝文件的载体。
 *
 * 科学家想要尽可能多地将计算机中的信息拷贝到软盘中，做到软盘中文件内容总大小最大。
 *
 * 已知该软盘容量为1474560字节。文件占用的软盘空间都是按块分配的，每个块大小为512个字节。一个块只能被一个文件使用。拷贝到软盘中的文件必须是完整的，且不能采取任何压缩技术。
 *
 * 输入描述
 * 第1行为一个整数N，表示计算机中的文件数量。1 ≤ N ≤ 1000
 * 接下来的第2行到第N+1行(共N行)，每行为一个整数，表示每个文件的大小Si，单位为字节。0 ≤ i < N,0 ≤ Si
 *
 * 备注
 *  为了充分利用软盘空间，将每个文件在软盘上占用的块记录到本子上。即真正占用软盘空间的只有文件内容本身。
 *
 * 输出描述
 * 科学家最多能拷贝的文件总大小
 */
public class CopyTheFile {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] fileArray = new int[n];
        for (int i = 0; i < n; i++) {
            fileArray[i] = scanner.nextInt();
        }
        scanner.close();

        int count = 1474560/512;
        int[] dp = new int[count + 1];
        for (int i = 0; i < fileArray.length; i++) {
            int size = fileArray[i];
            int actual  = (int) Math.ceil(size / 512.0);
            for (int j = count; j >= actual; j--) {
                dp[j] = Math.max(dp[j], dp[j - actual] + size);
            }
        }
        System.out.println(dp[count]);
    }
}
